ট্রি ভিত্তিক ডেটা স্ট্রাকচার: B-Tree, Red-Black Tree

অ্যাডভান্সড ডেটা স্ট্রাকচার (Advanced Data Structures in C) - সি দিয়ে ডেটা স্ট্রাকচার (DSA using C) - Computer Programming

447

ট্রি ভিত্তিক ডেটা স্ট্রাকচার: B-Tree, Red-Black Tree

ট্রি ভিত্তিক ডেটা স্ট্রাকচারগুলি, বিশেষ করে B-Tree এবং Red-Black Tree, ডেটা সংরক্ষণ এবং অনুসন্ধানে অত্যন্ত কার্যকরী। এই গঠনগুলির সাহায্যে বড় ডেটাসেটের সাথে দ্রুত কাজ করা যায় এবং তাদের মধ্যে সঠিক অর্ডার বজায় রাখা হয়।


B-Tree (Balanced Tree)

B-Tree একটি সোর্সিং ট্রি ডেটা স্ট্রাকচার যা বড় ডেটাসেটের জন্য ব্যবহৃত হয় এবং বিশেষ করে ডিস্ক স্টোরেজ বা ফাইল সিস্টেম ব্যবস্থায় ব্যবহৃত হয়। এটি এমন একটি স্ব-ব্যালেন্সিং ট্রি (Self-Balancing Tree) যা ডেটাকে সঠিকভাবে সংরক্ষণ এবং দ্রুত অ্যাক্সেস করার জন্য ডিজাইন করা হয়েছে।

B-Tree এর বৈশিষ্ট্য:

  1. পূর্ণ বাইনারি ট্রি নয়: B-Tree তে প্রতিটি নোডে একাধিক চাবি এবং সন্তান থাকতে পারে। অর্থাৎ, প্রতিটি নোডে একটি ভেরিেবল সংখ্যা চাবি থাকতে পারে এবং প্রতিটি চাবি থেকে দুটি সন্তান থাকতে পারে।
  2. অর্ডার (Order): B-Tree একটি অর্ডার k ট্রি হতে পারে, যার মানে প্রতিটি নোডে সর্বাধিক k-1 চাবি এবং k সন্তান থাকতে পারে।
  3. বিশাল ডেটার জন্য উপযোগী: এটি ডেটাবেস এবং ফাইল সিস্টেমে বড় আকারের ডেটাকে দ্রুত অনুসন্ধান, ইনসার্ট এবং ডিলিট করতে ব্যবহৃত হয়।
  4. সামঞ্জস্য বজায় রাখা: B-Tree একটি স্ব-ব্যালেন্সিং ট্রি, যার মানে হল যে সমস্ত পাথের গভীরতা সমান হয়, যা অনুসন্ধান সমতল রাখে।

B-Tree এর অপারেশন:

  • ইনসার্ট: নতুন চাবি ডালা হয় এবং যদি কোন নোড পূর্ণ হয়, তাহলে ডিভাইড করা হয়।
  • ডিলিট: চাবি মুছে ফেলা হয় এবং যদি কোনো নোড খুব কম চাবি থাকে, তাহলে পুনর্বিন্যাস করা হয়।
  • অনুসন্ধান: B-Tree তে অনুসন্ধান একটি লিনিয়ার ট্রাভার্সাল পদ্ধতি অনুসরণ করে।

B-Tree এর উদাহরণ:

ধরা যাক একটি B-Tree যার অর্ডার 3 (k=3)। এটি সর্বাধিক 2 চাবি ধারণ করতে পারে প্রতিটি নোডে।

       [10]
      /    \
 [3, 7]    [15, 20]
  /   \     /      \
[1]  [5]  [12]   [25, 30]

Red-Black Tree

Red-Black Tree একটি ব্যালেন্সড বাইনারি সার্চ ট্রি (BST) যা কিছু বিশেষ বৈশিষ্ট্য অনুসরণ করে। এটি ট্রি নোডগুলির মধ্যে রঙ দিয়ে একটি অতিরিক্ত শর্ত যোগ করে, যাতে ট্রি স্বয়ংক্রিয়ভাবে ব্যালেন্স থাকতে পারে।

Red-Black Tree এর বৈশিষ্ট্য:

  1. রঙ কোডিং: প্রতিটি নোডের দুটি রঙ থাকতে পারে: লাল অথবা কালো
  2. রঙের শর্ত:
    • রুট নোডটি সবসময় কালো।
    • কোনো দুটি লাল নোড একে অপরের সন্তানে থাকতে পারে না (লাল নোডের সন্তানের রঙ অবশ্যই কালো হতে হবে)।
    • প্রতিটি পাথের মধ্যে কালো নোডের সংখ্যা সমান থাকতে হবে।
    • প্রতিটি লাল নোডের দুইটি কালো সন্তানের সাথে সংযুক্ত থাকতে হবে।
  3. ব্যালেন্সিং: Red-Black Tree তে প্রতিটি পাথের মধ্যে কালো নোডের সংখ্যা সমান থাকে, ফলে এটি গ্যারান্টি দেয় যে ট্রির গভীরতা সীমিত থাকবে, যার ফলে অপারেশনগুলোর কার্যকারিতা নিশ্চিত থাকে।
  4. প্রয়োগ: Red-Black Tree সাধারণত সিস্টেম প্রোগ্রামিং, ডেটাবেস, এবং বিভিন্ন জটিল ডেটা স্ট্রাকচারে ব্যবহৃত হয়, যেমন **C++ STL (Standard Template Library)**।

Red-Black Tree এর অপারেশন:

  • ইনসার্ট: নতুন নোড ইনসার্ট করা হয় এবং পরে ব্যালেন্স করার জন্য কিছু রঙ পরিবর্তন এবং ঘূর্ণন প্রয়োগ করা হয়।
  • ডিলিট: নোড মুছে ফেলা হয় এবং গাছের ব্যালেন্স বজায় রাখতে ঘূর্ণন ও রঙ পরিবর্তন করা হয়।
  • অনুসন্ধান: রেড-ব্ল্যাক ট্রিতে অনুসন্ধান সাধারণ বাইনারি সার্চ ট্রির মতো করা হয়।

Red-Black Tree এর উদাহরণ:

এখানে একটি Red-Black Tree এর উদাহরণ দেখানো হয়েছে:

        10(B)
       /    \
    5(R)    20(R)
   /   \    /     \
 1(B)   7(B)  15(B)  25(B)

এখানে, প্রতিটি নোডের পাশে রঙ দেওয়া হয়েছে, এবং এটি নিশ্চিত করা হয়েছে যে কোনো দুটি লাল নোড একে অপরের সন্তানে নয়। এছাড়া, প্রতিটি পাথের কালো নোডের সংখ্যা সমান।


B-Tree এবং Red-Black Tree এর তুলনা:

বৈশিষ্ট্যB-TreeRed-Black Tree
ধরনএকটি স্ব-ব্যালেন্সিং ট্রিএকটি ব্যালেন্সড বাইনারি সার্চ ট্রি
ইনপুট ডেটাডিস্ক এবং ফাইল সিস্টেমের জন্য উপযুক্তকম্পিউটার মেমরির মধ্যে ইন-মেমরি ব্যবহৃত
ব্যালেন্সিং পদ্ধতিট্রি নোডের সংখ্যা নিয়ন্ত্রণনোডের রঙের শর্ত অনুযায়ী ব্যালেন্স করা
গভীরতাসীমিতO(log n) গ্যারান্টিযুক্ত গভীরতা
অপারেশনঅনুসন্ধান, ইনসার্ট, ডিলিটঅনুসন্ধান, ইনসার্ট, ডিলিট
প্রয়োগডেটাবেস এবং ফাইল সিস্টেমে ব্যবহারসিস্টেম প্রোগ্রামিং, ডেটাবেস

সারসংক্ষেপ:

B-Tree এবং Red-Black Tree দুটি গুরুত্বপূর্ণ ট্রি ভিত্তিক ডেটা স্ট্রাকচার, যা ডেটা সঞ্চয়, অনুসন্ধান এবং পরিচালনা করতে ব্যবহৃত হয়। B-Tree বড় ডেটাসেটের জন্য এবং ডিস্ক স্টোরেজ সিস্টেমের জন্য উপযুক্ত, কারণ এটি ডেটাকে সঠিকভাবে ব্যালেন্স করে রাখে এবং দ্রুত অনুসন্ধান করার সুবিধা দেয়। অন্যদিকে, Red-Black Tree একটি বাইনারি সার্চ ট্রি যা রঙের মাধ্যমে ব্যালেন্স বজায় রাখে এবং ইন-মেমরি ডেটা প্রসেসিংয়ে ব্যবহার করা হয়।

Content added By
Promotion

Are you sure to start over?

Loading...